PAT-NO:

JP404349535A

DOCUMENT-IDENTIFIER: JP 04349535 A

TITLE:

INFORMATION PROCESSOR

**PUBN-DATE**:

December 4, 1992

INVENTOR-INFORMATION: **NAME** KIKUCHI, SATOSHI HATANO, TOMIHISA

ASSIGNEE-INFORMATION:

**NAME** 

**COUNTRY** 

HITACHI LTD

N/A

APPL-NO: JP03123391

APPL-DATE:

May 28, 1991

INT-CL (IPC): G06F009/46, G06F013/00, H04N001/00, G06F012/06

## ABSTRACT:

PURPOSE: To develop the program without being conscious of an invasion of an address of a memory area by converting automatically an address of a static memory area accessed by the program to a dynamic address used by a task actually.

CONSTITUTION: In the case a communication request is generated, a task requests to actuate a communication control task. In this case in a program counter saving area of a TCB, an execution start address of a communication control program is registered, and the number of a free bank used for a bank number saving area is registered. An OS refers to the bank number saving area in the TCB of an actuated task, and informs the bank number to a memory managing part 4. The communication control program starts a processing from its execution start address, and in order to access a work area or an I/O area, an address of a bank window is outputted onto a bus 2. In this case, the memory managing part 4 converts the address of the bank window to an actual address.

COPYRIGHT: (C)1992, JPO& Japio

# (19)日本国特許庁 (JP)

# (12) 公開特許公報(A)

# (11)特許出願公開番号

# 特開平4-349535

(43)公開日 平成4年(1992)12月4日

| (51) Int.Cl. <sup>5</sup> G 0 6 F 9/46 13/00 H 0 4 N 1/00  / G 0 6 F 12/06 | 3 4 0 B 81<br>3 5 1 G 73<br>C 71 | 内整理番号 I<br>20-5B<br>68-5B<br>70-5C<br>41-5B | FI       |                       | 技術表示箇所                                            |
|----------------------------------------------------------------------------|----------------------------------|---------------------------------------------|----------|-----------------------|---------------------------------------------------|
|                                                                            |                                  |                                             | <b>7</b> | 等查請求 未請求              | 請求項の数3(全 7 頁)                                     |
| (21)出願番号                                                                   | 特顏平3-123391                      | (7                                          | 71)出顧人   | 000005108<br>株式会社日立製作 | 作所                                                |
| (22) 出願日                                                                   | 平成3年(1991)5月28                   |                                             | 72)発明者   | 菊地 聡<br>神奈川県横浜市戸      | 申田駿河台四丁目6番地<br>『塚区吉田町292番地株式<br>マイクロエレクトロニクス<br>内 |
|                                                                            |                                  | C                                           | 72)発明者   | 神奈川県横浜市戸              | 戸塚区吉田町292番地株式<br>マイクロエレクトロニクス<br>内                |
|                                                                            |                                  | (7                                          | 74)代理人   | 弁理士 小川 胆              | <b>券男</b>                                         |

#### (54) 【発明の名称】 情報処理装置

### (57)【要約】

【構成】プログラムがアクセスするメモリ領域のアドレスをタスクが使用するメモリ領域のアドレスに変換する 手段と、タスクが使用するメモリ領域の位置を特定する 情報を記憶する手段と、タスク実行時に使用するメモリ 領域の位置を前記アドレス変換手段に通知する手段を備 える。

【効果】プログラムがアクセスする静的なメモリ領域またはI/0空間のアドレスを、実際にタスクが使用する動的な領域のアドレスに自動変換するので、並列処理を意識しないで、容易にプログラムを開発することができる。



### 【特許請求の範囲】

【請求項1】マルチタスクOSの環境下で並列処理するプログラムを備えた情報処理装置において、前記プログラムがアクセスするメモリ領域のアドレスをタスクが使用するメモリ領域のアドレスに変換する手段と、前記タスクが使用する前記メモリ領域の位置を特定する情報を記憶する手段と、前記タスクの実行時に使用する前記メモリ領域の位置に関する情報を前記アドレス変換手段に通知する手段を備えることを特徴とする情報処理装置。

【請求項2】マルチタスクOSの環境下で並列処理する 10 プログラムを備えた情報処理装置において、前記プログラムは局所的なデータをアクセスする場合でもメモリ上の仮領域を静的にアクセスし、前記メモリ上の仮領域を指すアドレスを実際の動的な局所データ領域のでドレスに変換する手段と、実際の局所データ領域の位置を特定する情報を記憶する手段と、タスクの実行時に使用するメモリ領域の位置に関する情報を前記アドレス変換手段に通知する手段を備えることを特徴とする情報処理装置。

【請求項3】マルチタスクOSの環境下で並列処理する 20プログラムを備えた情報処理装置において、前記プログラムは局所的なI/0機器をアクセスする場合でもメモリ上の仮領域をI/0空間として静的にアクセスし、メモリ上の仮領域を指すアドレスを実際の動的な局所的な前記I/0空間のアドレスに変換する手段と、実際の局所的な前記I/0空間の位置を特定する情報を記憶する手段と、タスク実行時に使用する前記I/0空間の位置に関する情報を前記アドレス変換手段に通知する手段を備えたことを特徴とする情報処理装置。

#### 【発明の詳細な説明】

[0001]

【産業上の利用分野】本発明は、ファクシミリ装置等の 情報処理装置に係り、特に、一プログラムで複数の同等 処理タスクを並列実行する制御装置に関する。

[0002]

【従来の技術】現在、公衆電話網用G3ファクシミリは、約四百万台と広く普及している。これらの装置は、企業内ネットワークの発達等に伴い、通信に先立って原稿を読取り、一時メモリ等の配憶装置に格納した後、複数の相手先へ送信するメモリ同報送信機能に対する需要が大きい。

【0003】この同報送信には大きく分けて二種類ある。一つは、メモリ内の原稿を一相手先ずつ順番に送信する、順次、同報送信である。しかし、一旦、この機能を使用し始めると、連続送信する長い期間、その他の通信を待たさなければならない。そこで、通信トラフィックを削減するために複数の回線を用い、メモリ内の原稿を複数の相手先へ同時に送信する一斉同報送信機能を備えた基督もある。

【0004】また、公衆電話網に代って、データをデジ 50

タル二値のまま送信するサービス統合デジタル網(ISDN:Integrated Services Digital Network)が整備されてきた。このISDNは、音声、画像、データ等の各種通信サービスを統一インタフェースにより提供するもので、現在、基本インタフェースと一次群インタフェースが実用化されている。このうち、基本インタフェースは、一本の加入者線上に、64 Kbps (bits per second) の情報伝送チャネルを二本と、16 Kbpsの制御チャネルを一本備えている。

「【0005】このようなインフラストラクチャ確立の影響を受けて、ISDNのようなデジタル網に接続可能なG4ファクシミリが注目を浴びている。この装置は、一枚のA4原稿を数秒で送信し、更に400×400ppi (pels per inch) の高精細な画像通信を実現できる。またISDNに接続するG4ファクシミリは、二本の情報伝送チャネルを用いて、送信中の他相手先送信や受信中の送信等、同時通信機能を特徴とするものもある。

【0006】このように、これからのファクシミリ装置は、同時通信機能が大変重要な要素となる。

0 【0007】ここで、図4のシステム構成を用いて、従来の同時通信可能なファクシミリを説明する。

【0008】同図において、1は装置全体を制御する主制御部、2はデータやアドレスが流れるパス、5はプログラム等を格納するメインメモリ、7は原稿の画像データを格納する画像メモリ、8は原稿を読取るスキャナ及び原稿を印刷するプリンタで構成される読取記録部、9、10は画像データを圧縮又は伸長する画像変換部、11、12は画像データもしくは通信手順データを送受信するチャネル入出力部、13、14は通信チャネル又は回線である。また15、16は誤り再送制御やページ同期制御、種々の通信条件に関するネゴシェーション等、通信手順を実行する通信制御部である。

【0009】ユーザが読取記録部8に原稿をセットしたなら、主制御部1は、読取記録部8に対して原稿を読取り圧縮して画像メモリ7に格納するように指示する。読取記録部8が原稿の画像データを格納し終えたならば、主制御部1は、通信制御部、画像変換部、チャネル入出力部の使用状況を調査し、空いている各処理部に動作指示を出す。そして、通信制御部が相手装置と通信に使用する符号化方式や解像度等を取決め、画像変換部が画像メモリ7内の画像データを取決めた符号化方式及び解像度に変換し、チャネル入出力部がチャネルを介して相手装置へ送出する。

【0010】図3はこのシステムにおけるメインメモリ 5のメモリマップである。

【0011】以後の各システムは、ソフトウェアで実現する各種処理(ジョブ)をタスクという最適な単位に分割し、各タスクをマルチタスクオペレーティングシステム(OS)の環境下で並列動作させる。

【0012】メインメモリ5は、OSのプログラムを格

.3

納するエリア、OSが各タスクの動作状況管理に使用す るタスク制御プロック(TCB)、プログラムを格納す るエリアとワークエリア、そして各種1/0機器のデータ 入出力用I/Oポートをメインメモリ5にマッピングしたI /0エリア (I/0空間) で構成されている。

【0013】ここでは、通信制御部15をソフトウェア 制御のタスクAとする。タスクAの通信制御プログラム Aは、通信制御ワークエリアAを用いて処理を行い、画 像変換I/0エリアAとチャネル入出力I/0エリアAを介し て画像変換部9とチャネル入出力部11をアクセスす 10

【0014】次に同時通信について説明する。タスクA が通信手順を実行する間、幾つかの時点で、相手装置か らの応答を待つ等、ある事象が発生するまでタスクAが 休止状態となることがある。この期間を利用すれば、他 の相手装置との通信が可能である。しかし、このために 再びタスクAを起動すると、通信制御プログラムAがワ ークエリアAを破壊したり、画像変換部9やチャネル入 出力部11にデータを入出力してしまい、休止状態にあ るタスクAを再開させることができなくなる。

【0015】そこでこのシステムでは、図4から分かる ように、画像変換部、チャネル入出力部及びチャネルを 二組ずつ備えると共に、タスクBとしてもう一つの通信 制御部16を設ける。タスクBの通信制御プログラムB は、通信制御ワークエリアBを用いて処理を行い、画像 変換1/0エリアBとチャネル入出力1/0エリアBを介し て、画像変換部10とチャネル入出力部12をアクセス する。

【0016】この説明のように、従来のシステムは、二 通信のタスク各々にプログラムを設け、制御の流れは同 等の二プログラムをアクセスするワークエリア及び1/0 エリアのアドレスだけ変えて、メインメモリ5上に二つ 配置しなければならず、メモリ領域をむだに消費する。 また、プログラムをメンテナンスまたはエンハンスする 時、二ヵ所を修正しなければならず、デバッグ効率も良 くない。

【0017】そこで、従来のようにタスクとプログラム を一対一に対応させるのではなく、一つのプログラムを N個のタスクに対応させるプログラム構造が提案されて いる。この構造はリエントラント構造と呼ばれ、例え 40 ば、昭和63年8月、昭晃堂発行の「ローダとリンケー ジエディタ」に記載されている。

【0018】リエントラント(再入)可能なプログラム とは、複数のプログラムから同時に処理を指示されて も、問題なく実行するプログラムであり、処理する毎に 使用するワークエリアをメモリ上に個別に確保する。

【0019】図6はリエントラント構造を有する通信制 御部17を備えた装置のシステム構成であり、図5はそ のメモリマップである。

(タスクA及びB) が一つのリエントラント構造通信制 御プログラムを共有する。

【0021】例えば通信要求が発生したとき、図示しな い他のタスクはメインメモリ5上にワークエリアAを確 保する。そして、確保したワークエリアAと空いている 画像変換及びチャネル入出力I/0エリアAをタスクAに **通知し、処理を依頼する。依頼を受けたタスクAは、通** 知されたワークエリアAとI/OエリアAを用いて、通信 制御プログラムを実行する。

【0022】この処理中に、更に通信要求が発生した場 合は、図示しない他のタスクはメインメモリ5上に別の ワークエリアBを確保し、空いている画像変換及びチャ ネル入出力I/OエリアBと共に、タスクBへ処理を依頼 する。依頼を受けたタスクBは、タスクAとは異なるワ ークエリアB及びI/OエリアBを用いて、通信制御プロ グラムを実行する。

【0023】つまり、第一の従来例は、ワークエリア及 び1/0エリアとしてメインメモリ5上の静的な固定エリ アを使用するため、アクセスアドレスだけを変えた通信 20 制御プログラムをメインメモリ5上に二つ配置しなけれ ばならなかったが、第二の従来例は、通知された動的な エリアを使用するため、メインメモリ5上に一つ配置す れば良い。

[0024]

30

【発明が解決しようとする課題】現在のプログラミング 技術では、プログラム及び変数を再配置できるように、 プログラムや変数にアドレス定数という論理的な名称を 付加し、これを用いてプログラムがアクセスする方法が 一般的である。アドレス定数を用いたプログラムはアセ ンプラ、または、コンパイラ等によりオプジェクトプロ グラムに変換された後、リンカにより他のオブジェクト プログラムと結合されてメモリ上に並び、プログラム内 のアドレス定数を実際のワークエリアまたは1/0エリア のアドレスに置換される。

【0025】第一の従来方式では、通信制御プログラム Aと通信制御プログラムBは、互いに異なるアドレス定 数によりワークエリアまたは1/0エリアをアクセスする ので、相手のエリアを侵害することはない。

【0026】しかし、第二の従来方式のようなリエント ラント構造をもつプログラムが使用するワークエリア、 または、I/Oエリアは、実行時に始めて決まる動的なエ リアであり、アドレス定数を用いて、プログラムがアク セスするエリアを固定することはできない。

【0027】このため、リエントラント構造をもつプロ グラムは、実行する毎にワークエリア及び1/0エリアを 確保し、アドレスをポインタ変数として記憶する。そし て、記憶したポインタ変数を介して動的なエリアをアク セスする。

【0028】しかし、ポインタ変数による間接的なメモ 【0020】このシステムでは、二つの通信制御タスク 50 リアクセスは、プログラミング言語またはCPUによっ

てはサポートされていないものもある。また、サポート されていても、アドレス定数による直接的なメモリアク セスを用いたプログラムのように、容易に開発すること はできない。

【0029】本発明の目的は、アクセスするワークエリア、及び、I/0エリアとして静的なエリアを使用しながらも、一プログラムを並列処理させることが可能な制御方法をもった情報処理装置を提供することにある。

#### [0030]

【課題を解決するための手段】前記目的達成のため、本 10 発明は、マルチタスクOSの環境下で並列処理するプログラムを備えたファクシミリ装置、または、情報処理装置において、プログラムがアクセスするメモリ領域のアドレスをタスクが使用するメモリ領域のアドレスに変換する手段と、タスクが使用するメモリ領域の位置を特定する情報を記憶する手段と、タスク実行時に使用するメモリ領域の位置に関する情報を前記アドレス変換手段に通知する手段を設けたものである。

【0031】さらに本発明は、マルチタスクOSの環境下で並列処理するプログラムを備えたファクシミリ装置 20または情報処理装置において、前記プログラムは局所的なデータをアクセスする場合でもメモリ上の仮領域を静的にアクセスし、メモリ上の仮領域を指すアドレスを実際の動的な局所データ領域のアドレスに変換する手段と、実際の局所データ領域の位置を特定する情報を記憶する手段と、タスク実行時に使用するメモリ領域の位置に関する情報を前記アドレス変換手段に通知する手段を設けたものである。

【0032】さらに、本発明は、マルチタスクOSの環境下で並列処理するプログラムを備えたファクシミリ装 30 置または情報処理装置において、前記プログラムは局所的なI/0機器をアクセスする場合、メモリ上の仮領域をI/0空間として静的にアクセスし、メモリ上の仮領域を指すアドレスを実際の動的な局所I/0空間の位置を特定する情報を記憶する手段と、実際の局所I/0空間の位置を特定する情報を記憶する手段と、タスク実行時に使用するI/0空間の位置に関する情報を前記アドレス変換手段に通知する手段を設けたものである。

#### [0033]

【作用】本発明の情報処理装置によれば、前記アドレス 40 変換手段は、アクセスするメモリ領域のアドレスを使用するメモリ領域のアドレスに自動的に変換する。このため、あるプログラムを複数並列に処理する場合でも、各タスクの前記メモリ領域の記憶手段に異なる位置を設定しておけば、並列処理しているタスク間で、他タスクのメモリ領域を侵害することがない。

### [0034]

【実施例】以下、本発明に係るファクシミリ装置の実施 例について説明する。

【0035】図2は本発明の第一の実施例に関するファ 50 する。この時、TCBのプログラムカウンタ退避エリア

クシミリ装置のシステム構成であり、図1はメモリマップである。

【0036】従来例のシステム構成(図4または6)と 異なる点は、メモリ管理部4及びパンクメモリ6を備え ることである。

【0037】図1に示すように、メインメモリ5上に は、OS、TCB、通信制御プログラムに加え、パンク ウィンドウを配置する。 パンクウィンドウには、 ウィン ドウサイズに合わせて分割されたパンクメモリ6(以 下、分割されたパンクメモリの個々をパンクとする)を 反映させてあり、ある時点でパンクウィンドウには一つ のパンクが写しだされる。それぞれのパンクはパンク番 号というユニークな番号で管理され、メモリ管理部4 が、実行すべきパンクをパンクウィンドウに写しだすよ う切換制御する。本実施例では、パンクウィンドウに二 つのパンク20、21を対応させ、それぞれのパンク に、通信制御ワークエリア、画像変換1/0エリア、チャ ネル入出力1/0エリアを割り当てている。通信制御プロ グラムは、ワークエリア及び1/0エリアとして、パンク ウィンドウという静的なエリアをアクセスするようにコ ーディングされている。また、1/0機器の入出力用1/0ポ ートは、パンク20もしくはパンク21の1/0エリアに 相当するアドレスに割付ける。

【0038】図7はタスクの動作を管理するタスク制御プロック(TCB)の構造である。TCBには、タスクが次に実行を始めるプログラムアドレスを格納するプログラムカウンタ退避エリアと、タスクが使用するパンクの番号を格納するパンク番号退避エリアを設け、同時二 通信まで処理できるように、一つの通信制御プログラムに対して、二タスクA、BのTCB18、19を用意する

【0039】図8は、メインメモリ5上のパンクウィンドウ及びパンクメモリの配置例を示すものである。本実施例では、メインメモリ5のアドレス「D000日」から「EFFF日」をパンクメモリ6に割当てている。また、パンクウィンドウはメインメモリ5上のアドレス「C000日」から「DFFF日」をパンク20、アドレス「B000日」から「DFFF日」をパンク21としている。このとき、パンク番号はそれぞれ1及び2とする。通信制御プログラムがワークエリアまたはI/Oエリアをアクセスする際は、アドレス「C000日」から「CFFF日」のパンクウィンドウをアクセスする。そのとき、メモリ管理部4は、そのアクセスするエリアのアドレスを、起動中のタスクに応じてパンク20またはパンク21のアドレスに変換する。

【0040】次に、本発明のファクシミリ装置における 同時通信処理方式を説明する。

【0041】通信要求が発生した場合、図示しない他の タスクは、OSに対して、通信制御タスクの起動を要求 する。この時、TCBのプログラムカウンタ退避エリア

に、通信制御プログラムの実行開始アドレスを登録し、 更に、パンク番号退避エリアに使用する空きパンクのパ ンク番号を登録しておく。

【0042】図9は、OSがタスクの起動要求を受けた場合、そのタスクの実行に先立つディスパッチ処理を示すものである。

【0043】まず、OSは起動するタスクのTCB内のパンク番号退避エリアを参照し(ステップ901)、メモリ管理部4にパンク番号を通知する(ステップ902)。このとき必要ならば、パンク内の変数等を初期化する。次に、同じTCB内のプログラムカウンタ退避エリアに格納されたアドレスからプログラムを実行する(ステップ903)。

【0044】通信制御プログラムはその実行開始アドレスから処理を始め、ワークエリアまたはI/0エリアをアクセスするために、バス2上にパンクウィンドウのアドレスを出す。このとき、メモリ管理部4は、バンクウィンドウのアドレスを実際のパンクのアドレスに変換する。

【0045】図10はメモリ管理部4のアドレス変換処 20 理を示すものである。

【0046】メモリ管理部4は、バス2を監視し、アドレスが出力されるのを特つ(ステップ1001)。アドレスが出力されたならば読込み(ステップ1002)、バンクウィンドウのアドレスであるか確認する(ステップ1003)。もし、バンクウィンドウのアドレスでなければ、次のステップ1004,1005を実行しない。しかし、バンクウィンドウのアドレスである場合は、図9のステップ902においてOSから通知されたバンク番号を読込み(ステップ1004)、そのバンク番号に16進の「1000日」を乗算し、アドレスに加算する(ステップ1005)。

【0047】次に、アドレスがI/0エリアを指しているか確認する(ステップ1006)。もしI/0エリアではない場合、メインメモリ5またはパンクメモリ6の該当のアドレスをアクセスする(ステップ1007)。I/0エリアの場合は、対応するI/0機器をアクセスする(ステップ1008)。

【0048】例えば、最初の通信要求に対して、タスクAがTCB18及びパンク20を用いて実行されると、プログラムがアクセスする「COOOB」から「CFFFEI」のアドレスは、「DOOOE」から「DFFFEI」のアドレスに変換される。そして、タスクAが実行中に別の通信要求が発生した場合、図示しない他のタスクは、通信制御TCB19及びパンク21によるタスクBの起動を依頼すれば、プログラムがアクセスする「COOOE」から「CFFFEI」のアドレスは、「BOOOE」から「EFFFEI」のアドレスに変換される。

【0049】このように、各タスクが共有しているプログラムは、静的なパンクウィンドウ上に配置した仮のワ 50

ークエリア及びI/0エリアを、例えば、アドレス定数でアクセスすることにより、パンクメモリ6上の各タスクが使用する動的なワークエリア及びI/0エリアを自動的にアクセスできる。

【0050】また、第一の実施例では一パンクを一タスクが占有しているが、装置の仕様によっては複数のタスクで一パンクを共有しても良い。さらに第一の実施例では、全てのワークエリア及びI/0エリアをパンクに割り当てているが、タスク間で侵害しないワークエリア及び101/0エリアはメインメモリ5上に割り当てても良い。

【0051】以上の点を考慮したシステムのメモリマップを図11に示す。

【0052】本実施例のシステムは三プログラムから成る。この内、Zプログラムは一つのタスクに使われるが、Xプログラム及びYプログラムは並列処理の可能性があるため、各々タスクAとB及びタスクCとDでプログラムを共有する。また、各タスクで競合しないエリアは、タスク共通ワークエリア及びタスク共通I/0エリアとしてメインメモリ5上に配置する。

20 【0053】本実施例では、一パンクにX及びYプログラムのワークエリアとI/0エリアを配置し、一パンクをニプログラムで共有する。例えば、Xプログラムに対応づけられるタスクAとB、及びYプログラムに対応づけられるタスクCとDとを連動して実行させる場合等は、並列処理させるために、第一の実施例では四パンク必要であるが、本実施例では、XタスクAとYタスクCのTCB内パンク番号退避エリアに同一パンク20のパンク番号を設定し、XタスクBとYタスクDのTCB内パンク番号退避エリアに同一パンク21のパンク番号を設定することで、ニパンクで済み、更にXタスクまたはYタスクは、連動しているタスクのワークエリア及びI/0エリアを容易に参照することもできる。

【0054】以上説明した実施例はファクシミリ装置に 関するものであるが、本発明は一プログラムを並列処理 させる全ての情報処理装置にも適用可能である。

[0055]

【発明の効果】本発明のファクシミリ装置及び情報処理 装置によれば、プログラムがアクセスする静的なメモリ 領域のアドレスを、実際にタスクが使用する動的なメモ リ領域のアドレスに自動変換する。このため、並列処理 するタスクのメモリ領域のアドレスを侵害することがな いように意識せずに、容易にプログラムを開発すること ができる。

#### 【図面の簡単な説明】

【図1】本発明の第一の実施例のメモリマップ、

【図2】本発明の第一の実施例のシステムプロック図、

【図3】第一の従来装置のメモリマップ、

【図4】第一の従来装置のシステムプロック図、

【図5】第二の従来装置のメモリマップ、

【図6】第二の従来装置のシステムプロック図、

【図7】本発明のタスク制御ブロック(TCB)の説明 87

【図8】 本発明のパンクメモリの構成例を示す説明図、

【図9】本発明のOSディスパッチ処理を表すフローチャート、

【図10】本発明のメモリ管理部の処理を表すフローチ

【図11】本発明の第二の実施例のメモリマップ。 【符号の説明】 1…主制御部、

2…パス、

5…メインメモリ、

7…画像メモリ、

8…読取記録部、

9, 10…画像変換部、

11, 12…チャネル入出力部、

10

13, 14…回線。



【図10】

【図11】

